package com.yuehuanghun.admin.core.domain;

import java.io.Serializable;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;

import javax.persistence.Transient;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonFormat.Shape;
import com.yuehuanghun.admin.core.config.annotation.mybatislilu.CreateTime;
import com.yuehuanghun.framework.annotation.Excel;
import com.yuehuanghun.framework.annotation.Excel.ColumnType;
import com.yuehuanghun.mybatis.milu.annotation.AttributeOptions;
import com.yuehuanghun.mybatis.milu.annotation.ExampleQuery;
import com.yuehuanghun.mybatis.milu.annotation.ExampleQuery.MatchType;
import com.yuehuanghun.mybatis.milu.annotation.alias.id.SnowflakeId;

import lombok.Data;

/**
 * 系统访问记录表 sys_logininfor
 * 
 * @author yadmin
 */
@Data
public class SysLogininfor implements Serializable {
	private static final long serialVersionUID = 1L;

	/** ID */
	@Excel(name = "序号", cellType = ColumnType.NUMERIC)
	@SnowflakeId
	@JsonFormat(shape = Shape.STRING)
	private Long infoId;

	/** 用户账号 */
	@Excel(name = "用户账号")
	@AttributeOptions(exampleQuery = @ExampleQuery(matchType = MatchType.CONTAIN))
	private String userName;

	/** 登录状态 0成功 1失败 */
	@Excel(name = "登录状态", readConverterExp = "0=成功,1=失败")
	private String status;

	/** 登录IP地址 */
	@Excel(name = "登录地址")
	@AttributeOptions(exampleQuery = @ExampleQuery(matchType = MatchType.CONTAIN))
	private String ipaddr;

	/** 登录地点 */
	@Excel(name = "登录地点")
	private String loginLocation;

	/** 浏览器类型 */
	@Excel(name = "浏览器")
	private String browser;

	/** 操作系统 */
	@Excel(name = "操作系统")
	private String os;

	/** 提示消息 */
	@Excel(name = "提示消息")
	private String msg;

	/** 访问时间 */
	@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
	@Excel(name = "访问时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
	@CreateTime
	private Date loginTime;

	/** 请求参数 */
	@Transient
    private Map<String, Object> params;
	
	public Map<String, Object> getParams() {
		return params == null ? (params = new HashMap<>()) : params;
	}
}
